WO 2005/010818 ·

PCT/JP2004/011010

# IAP20 Res'd PCT/PTO 26 JAN 2006

明 細 書

## 発明の名称

画像処理装置、画像処理方法及び歪補正方法

### 技術分野

本発明は、主に、デジタルカメラ等の電子的撮像装置に用いられる画像処理装置及び画像処理方法に関し、特に、回路規模やデータ転送量を増大させること無く、歪補正機能を実現し、小領域(例えばブロックライン)単位での歪補正処理を行う場合に、小領域の空間的な位置を算出可能とした画像処理装置、画像処理方法及び歪補正方法に関する。

### 背景技術

デジタルカメラ、銀塩カメラを問わず、一般的にカメラの光学系においては歪曲収差が現れる。また、現在発売されているカメラでは、光学ズームが可能な機種が殆どであり、その場合、ワイド端からテレ端にかけて、歪曲収差の状態が変化する。ワイド端では樽型歪が多く、テレ端では糸巻き型歪が多い。

歪曲収差は、例えば格子状の被写体を撮影すると、樽型歪、糸巻き型歪として 観測される。

図56は格子状の被写体、図57は樽型歪を生じた撮影画像、図58は糸巻き型歪を生じた撮影画像である。

ところで、デジタルカメラにおいては、CCD等の撮像素子のデータに対し、 様々な画像処理を行なった後、JPEG等の圧縮方式で圧縮したデータをメモリ カード等の記録媒体に記録する。

図59は一般的なデジタルカメラで行われている画像処理手順の概念を示している。CCDにより取り込まれた撮像信号にプリプロセスで画素欠陥処理、A/D変換等を行い、得られた画像データをSDRAM等のフレームメモリに一旦記憶する。次に、フレームメモリから読み出された画像データに対してイメージプ

ロセスにより各種の画像処理を行い、さらにJPEG処理で画像圧縮して記録媒体としてのメモリカード等に記録する。

図60は従来のデジタルカメラの画像処理装置のブロック図 (例えば特開200-312327号公報での従来例)を示している。

図6 0において、従来の画像処理装置は、バス 103 に C P U 104 と共にプリプロセス回路 102,複数のイメージプロセス回路 106-1~106-n,J P E G 処理部 1 07,フレームメモリ 105 及び記録媒体としてのメモリカード 108 が接続されている。そして、C P U 104 の制御により、C C D 101 からの撮像信号がプリプロセス回路 102 で画素欠陥処理やA / D 変換等が施された後、バス 103 を通してフレームメモリ 105 に一旦記憶される。次に、フレームメモリ 105 から画像データを読み出し、バス 103 を通してイメージプロセス回路 106-1 に入力して所定の画像処理を行い、再びバス 103 を通してフレームメモリ 105 に書き直す。以下同様にして、バス 103 を介してフレームメモリ 105 とイメージプロセス回路 106-2~106-n との間でデータのやり取りを順次行って、最後にJ P E G 処理部 107 でJ P E G 圧縮処理を行い、画像処理したデータをフレームメモリ 105 に一旦記憶し、フレームメモリ 105 から読み出した処理データをメモリカード等 108 に記録するようになっている。以上の各段のイメージプロセス及びJ P E G 処理では、小領域(ブロックライン)を単位として画像処理が行われる。

ところで、イメージプロセス回路の少なくとも1つにおいて図56~図58で述べたような歪補正処理を行う方法として、下記の光学的に表現される歪補正式 [式5]を用いることによって撮像画像の歪曲収差を補正することが行われる。 [式5]

$$Z^{2} = (X - X_{d})^{2} + (Y - Y_{d})^{2}$$

$$\begin{cases} X' = (X - X_{d}) \cdot [1 + A \cdot Z^{2}] + X_{d} \\ Y' = (Y - Y_{d}) \cdot [1 + A \cdot Z^{2}] + Y_{d} \end{cases}$$

$$(X. Y) : 補正画像内での座標 (X', Y') : 撮影画像内での座標 (X_{d}, Y_{d}) : 歪中心位置 A : 歪補正係数$$

しかしながら、光学的に表現される上記の[式5]を用いて歪補正を行った場合、補正画像に過不足が生じる。

図61,図62は樽型歪,糸巻き型歪を生じた撮影画像を、上記の[式5]によって補正する動作を説明するものである。

図61は点線のように樽型に歪んだ元画像(図示左)を[式5]にて補正した場合であって、補正された画像(図示右)は画像出力範囲からはみ出して無駄になる部分を生じている。

図62は点線のように糸巻き型に歪んだ元画像(図示左)を [式5] にて補正 した場合であって、補正された画像(図示右)は画像出力範囲より小さくなりデ ータが不足する部分が生じる。

このような図61,図62の不具合に対して、先行出願である日本国特開平9 -098340号公報では、歪補正後に、電子ズームを行うことで補正により伸 長した分を縮小して元の位置まで戻して、歪補正により失われる画像情報を最小 限に抑えている。

一方、通常、CCD等の撮像素子の読み出しは、(1) 本撮影用の全画素読み出し、(2) スルー画用の間引き読み出し、の2種類の読み出しが可能である。間引き読み出し等によって、撮像したデータから一部を取り込んだ画像データは、アスペクト比が1:1ではないため、そのままでは正確な歪補正が行えない。

また、従来、この画像処理の一部として歪補正を行う先行技術が開示されている。例えば、特開平 6-181530号公報,特開平 10-224695号公報がある。

特開平6-181530号公報には、撮影時における撮像ズームレンズの撮像ボジションが歪曲収差の大きいボジション内であることが検出手段にて検出されている場合には、この撮像ズームレンズによって生じた像の幾何学的歪みを、固体撮像素子の撮像データを幾何学的変形に基づき読み出すことにより補正することが記載されている。

特開平10-224695号公報には、光学系を経由した光を受光する固体撮

像デバイスで撮像したデータをランダムアクセスビデオメモリに記憶し、ランダム読み出しタイミング発生回路は光学系によって生ずる収差を補正するための収差補正データを有し、この収差補正データに基づいて固体撮像デバイスによって生成された信号を所定の順に読み出してビデオ信号を生成することで、光学系の歪曲収差を補正することが記載されている。

しかしながら、特開2000-312327号公報では、フレームメモリと各イメージプロセス回路間でデータのやり取りが多く、バスのデータ転送量が増大する。さらに、小領域(ブロックライン)単位での歪補正処理については全く記載されていない。

また、特開平9-098340号公報では、樽型歪の補正にしか言及しておらず、撮像中心に一番近い点を基準にしており、原理的に樽型歪の補正のみである。 糸巻き歪に対しては、補正された画像が画像出力範囲より小さくなり画像データが不足する部分が生じる。さらに、図22に示すような陣笠型歪を補正するには、歪補正式に4次項以上が必要になるが、元画像データを最大限使うための補正倍率Mを解析的に求めることが困難であった。

特開平6-181530号公報では、歪補正処理を行うことが述べられているが、図36に示すようにCCDの撮像面における画素(黒丸印にて示される縦横の格子点)31に対して、本来直線であるべき被写体像が光学レンズの歪曲収差により湾曲して結像(符号32にて示す)すると、歪曲収差補正回路内のラインメモリに大容量バッファメモリが必要となる。また、バッファメモリの容量で処理できる画像サイズが制限されてしまう。さらに、バッファメモリに保持されているデータの空間的な位置の確定方法等についての記載がない。さらに、特開平6-181530号公報では、小領域(ブロックライン)単位での歪補正処理については全く記載されていない。

また、特開10-224695号公報では、ランダムアクセスで処理するのに、 バッファメモリは必要ないが、一般的にSDRAM等のメモリをランダムアクセ スすると、転送時間がかかる。 そこで、本発明の第1の目的は、撮像した元データを有効に活用して歪補正処理を行い、補正した画像が画像出力範囲に対して無駄なく有効に出力でき、糸巻き型歪、樽型歪、及び陣笠型歪にも対応できる歪補正処理が可能な画像処理装置及び画像処理方法を提供することである。

本発明の第2の目的は、小領域(例えばブロックライン)の空間的な位置を算出可能とし、小領域単位での歪補正処理を実現可能とした画像処理装置及び歪補正方法を提供することである。

本発明の第3の目的は、間引き取り込みされた画像データに対しても、正確な 歪補正を行える一方、デジタルズームなど、任意領域を切り出したデータに対し ても正確な歪補正を行える画像処理装置及び歪補正方法を提供することである。

本発明の第4の目的は、バスの転送量やメモリの容量を大きく増大させることなく、歪補正処理を実現できる画像処理装置及び画像処理方法を提供することである。

## 発明の開示

本発明による画像処理装置は、歪補正手段を有する画像処理装置であって、該 画像処理装置は、さらに、前記歪補正手段が歪補正処理を行う入力画像範囲を算 出する歪補正範囲算出部を有する。

このように、歪補正処理を行う入力画像範囲を算出する歪補正範囲算出部を設けることにより、出力画像(即ち、歪補正後の画像)の出力範囲の一部または全部に相当する領域が入力画像(即ち、撮像画像)内に占める範囲を算出することで、歪補正によって得られる補正画像は出力すべき出力範囲に対して過不足なく出力することが可能となり、出力範囲に対して補正画像がはみ出したり不足したりすることのないようにできる。

好ましくは、前記歪補正範囲算出部は、補間座標を生成する座標生成部と、前記生成された補間座標に対して所定の歪補正式を適用して変換した座標を出力する歪補正座標変換部と、前記変換された座標位置から前記入力画像範囲を算出す

る補正範囲検出部と、を有する。

この構成で、補間座標を生成するとは、歪補正前の撮像画像 (入力画像) の位置を求めるために、出力されるべき補正後の補正画像 (出力画像) の位置を前もって生成することである。この補間座標に対して歪補正式を適用して、歪補正前の画像位置 (座標) を生成 (変換) 出力させ、変換された補正前の座標位置から 歪補正処理すべき入力画像範囲を算出するようにしている。

或いは、好ましくは、前記歪補正範囲算出部は、座標変換により生成された座標に対し、前記出力画像範囲の4辺の各辺に対応する画素の座標の最大値と最小値および前記出力画像範囲の4頂点に対応する座標の少なくともいずれかから前記入力画像範囲を算出する。この構成で、4頂点とは、歪補正後の出力画像における各辺の頂点を指している。

或いは、好ましくは、前記歪補正範囲算出部は、歪補正処理を行う複数入力信号に対して順次範囲算出を繰り返して前記入力画像範囲を算出する。

この構成では、複数のチャンネルを扱う場合に、複数入力信号に対して同時に 歪補正処理を行っている間に、複数入力信号に対してそれぞれ次の処理対象であ るブロックラインにつき歪補正範囲算出を順次に繰り返して行うことで、1つの 歪補正範囲算出部で複数チャンネル分の範囲算出を行わせることが可能である。

好ましくは、前記範囲算出を繰り返し処理で行い、入力画像範囲に対して歪補 正後の画像範囲が所定の範囲になるような補正倍率Mを決定する。

この構成により、補正倍率Mを適宜の値に決定することで、陣笠型歪にも対応可能となる。

好ましくは、前記歪補正範囲算出部は、前記歪補正処理部が歪補正実行中に、 次に歪補正を行う画像入力範囲を算出する。

この構成では、歪補正実行中に、次に歪補正を行う画像入力範囲を算出するので、1つのブロックラインの歪補正が終わったときには次の歪補正処理を行う画像入力範囲が分かっており、歪補正処理を次のブロックラインに対して順次スムーズに行なっていくことが可能である。

本発明による画像処理方法は、歪補正処理を行う画像処理方法であって、前記 歪補正処理を行うに際して、歪補正処理を行う入力画像範囲を算出する。

このように、歪補正処理を行うに際して、歪補正処理を行う入力画像範囲を算出することにより、歪補正後の画像の出力範囲の一部または全部に相当する領域が入力画像内に占める範囲を算出することで、歪補正によって得られる補正画像は画像出力範囲に対して過不足なく出力することが可能となり、画像出力範囲に対して補正画像がはみ出したり不足したりすることのないようにできる。

本発明による画像処理装置は、画像データに対して歪補正処理を行う歪補正手段を有する画像処理装置において、前記歪補正手段は、補正前の画像データ内において、補正画像の各画素が対応する位置を所定の補正式に従って算出する際、 撮像面における空間的な位置を記述可能な座標系において算出する。

この構成では、補正前の画像データ内において、補正画像の各画素が対応する 位置を算出する際、撮像面に対応する座標系(即ち2次元空間における位置)を 基準にして計算を行う。

近好ましくは、前記歪補正手段は、補正画像に含まれる第1の小領域を単位に処理を行い、前記第1の小領域の各画素の座標位置を前記補正式に従って変換した小領域を含む撮像面における第2の小領域について、前記撮像面に対応する座標系での位置を、前記第2の小領域での座標に変換した後に、前記補正画像の各画素のデータを生成する。

この構成では、変換される小領域内での座標に基づいて、補間処理を行うことができる。

なお、前記画像データは、撮像データの一部のみを取り込んだ部分画像データ であってもよい。

画像データとしては、撮像したデータ全てではなくその一部、例えばデジタルズームの際に撮像データの中央部分から切り出されるデータや、撮像データから間引きによって生成される縮小データに対しても、適用することができる。

また、前記画像データは、前記撮像データに対してフィルタリング、空間サン

プリングまたは補間処理の少なくともいずれか1つを行って<del>生成さ</del>れるデータであってもよい。

画像データとしては、周波数的に制限するフィルタリングを行ったり、撮像デバイスの撮像面のような2次元的空間から適宜にサンプリングしたり、補間処理 (標本化処理などで離散化した画素と画素の間に、周囲の画素からの推定によって画素を作り出す処理) したり、することによって得られるデータなどがある。

本発明による歪補正方法は、画像データに対して歪補正処理を行う歪補正手段を有する画像処理装置の歪補正方法であって、前記歪補正方法は、補正画像の各画素に対応する座標系での第1の位置を生成するステップと、前記第1の位置を、歪補正式に従って歪補正前の画像データ内における座標系での第2の位置に変換するステップと、前記歪補正前の画像データ内における座標系での第2の位置を、撮像面に対応する座標系を基準とする設定領域内での座標に変換するステップと、前記設定領域内での座標に基づいて補間処理を行い、前記補正画像の各画素のデータを生成するステップと、を有する。

この歪補正方法では、例えば撮像レンズによる幾何学的歪みを補正する補正式によって、補正画像の各画素のデータを得る際には、補正画像の各画素に対応する座標系での第1の位置に対して、歪補正式に従って歪補正前の画像データ内における座標系での第2の位置に変換し、この変換された第2の位置を、撮像面に対応する座標系を基準とする設定領域内での座標に変換し、この座標に基づいて補間処理を行って補正画像の画素データを生成する。

好ましくは、前記補正画像に含まれる小領域を単位に処理を行う。

この方法では、補正画像に含まれる小領域(例えばブロックラインと呼ばれる 領域)を単位に処理を行うものである。

本発明による画像処理装置は、画像データに対して歪補正処理を行う歪補正手段を有する画像処理装置において、前記歪補正手段は、前記画像データの一部を格納するメモリ部と、前記メモリ部に対するデータの書き込みおよび読み込みを制御するメモリ制御部と、を有し、前記メモリ部から読み出した画像データに対

する補間演算を行う。

この構成では、内部バッファとしてのメモリ部に画像データの一部を格納して、 そのデータを利用して歪補正処理のための補間演算を行うことができる。

好ましくは、前記メモリ制御部は、前記メモリ部への書き込みの際は、列方向に一列に並んだ一定数分の画素からなる画像データ(ユニットライン: UL)を単位として書き込むように制御し、前記メモリ部からの読み出しの際は、歪補正処理後の画像が前記ULを単位として出力されるように、前記メモリ部に格納された画像データに対して読み出し制御する。

この構成では、メモリ部に対してULを単位として書き込み、読み出しを行うので、メモリ部のバッファ容量としては光学的歪量に応じて数UL分、すなわち少なくとも1UL分の容量があればよく、バスの転送量やメモリの容量を大きく増大させることなく、歪補正を実現できる。

さらに、好ましくは、前記メモリ制御部は、前記ULの最初に処理される画素の座標位置に対して、行方向に対して前側および後側に所定幅の領域(それぞれ p-reULB、postULB)を設け、前記ULの処理中は他の処理によって前記領域が上書きされないよう制御する。

この構成により、処理に必要なバッファとしてのメモリ部の前記preULB、 postULBの領域のデータが上書きされないよう確保できる。

好ましくは、前記画像処理装置は、さらにバッファの空き領域を検出するバッファ空き容量監視回路を有し、該バッファ空き容量監視回路によりバッファ内の空き領域が検出されると、該空き領域へのデータの書き込みを可能とする。

この構成により、データ出力中に入力も可能なパイプライン的な動作を可能とする。

好ましくは、前記メモリ部は、データのリード動作とライト動作が同時に可能な複数のメモリからなり、前記メモリ制御部は、さらに、前記メモリ部へのデータ書込み制御を行う書込みアドレス生成回路と、前記メモリ部に格納されている画像データから補間演算に必要なデータを同時に読み出すためのアドレスを生成

する読出しアドレス生成回路と、を有し、前記データ書込み制御は、同時に読み 出すデータをそれぞれ異なるメモリに書き込むものである。

この構成によれば、バッファ内にある画像データから、補間演算に必要なデータとして任意の座標の周辺の複数の画素 (例えば、16画素)情報を同時に読み出すことが可能となり、演算処理を速やかに行える。

本発明による画像処理方法は、画像データに対して歪補正処理を行う画像処理 方法において、前記歪補正処理を行う際には、データの書き込みおよび読み込み が制御されるメモリ部に、前記画像データの一部を格納し、該メモリ部から読み 出した画像データに対して補間演算を行う。

この方法では、内部バッファとしてのメモリ部に画像データの一部を格納して、 そのデータを利用して歪補正処理のための補間演算を行うことができる。

## 図面の簡単な説明

図1は本発明の第1の実施の形態の画像処理装置の全体構成を示すブロック図である。

図2は歪補正処理部の構成を示すブロック図である。

図3~図5は歪補正処理部における座標変換の概念図であり、図3は撮像画像 データを示す図、図4は補正画像を示す図、図5は補間処理を説明する図である。

図6は画像データの読み出し順序を示す図である。

図7は第1データ順序変換部におけるデータ順序変換処理を説明する図である。

図8は第2データ順序変換部におけるデータ順序変換処理を説明する図である。

図9はブロックラインと歪補正処理に必要なメモリ容量 (バッファ容量) の関係を示す図である。

図10はブロックライン幅の設定方法を示す図である。

図11は歪補正範囲算出部の構成を示すブロック図である。

図12及び図13は歪補正範囲算出部における、歪補正処理を行う際の入力画像範囲を算出する動作を説明する図であり、図12は補正画像上の範囲を示す図、図13は元データ上の範囲を示す図である。

- 図14は歪補正処理の動作を説明するフローチャートである。
- 図15は図14のステップS 11 における補正倍率Mの算出方法を説明するフローチャートである。
  - 図16は図11の歪補正範囲算出部の構成を示すプロック図である。
  - 図17は図16のデータ出力のタイミングチャートである。
- 図18は図17の動作を改善したもので、パイプラインでのデータ出力のタイミングチャートである。
- 図19は3チャンネル分の歪補正処理を行う際の入力画像範囲を算出する方法を説明する図である。
- 図20は3チャンネルの場合の歪補正処理の動作を説明するフローチャートである。
- 図21は本発明の第2の実施の形態の画像処理装置の全体構成を示すブロック 図である。
  - 図22は陣笠型の歪を生じた撮影画像を示す図である。
- 図23及び図24は補正前の撮像画像データと補正後の補正画像の関係を示す 図であり、図23は補正前の撮像画像データを示す図、図24は補正後の補正画 像を示す図である。
  - 図25は図23及び図24の歪補正処理のフローチャートである。
- 図26及び図27は、デジタルズームの場合で、補正前の撮像画像データと補 正後の補正画像の関係を示す図であり、図26は補正前の撮像画像データを示す 図、図27は補正後の補正画像を示す図である。
- 図28及び図29は、撮像データから或る領域を切り出す場合で、補正前の撮像画像データと補正後の補正画像の関係を示す図であり、図28は補正前の撮像画像データを示す図、図29は補正後の補正画像を示す図である。

10 11 114

図30~図32はCCDのモニターモードにおけるライン間引きを説明する図であり、図30はCCDから撮像時のデータを縦方向に3ライン間引いてメモリに取り込む状態を説明する図、図31はメモリに取り込まれた状態の撮影画像データを示す図、図32は縦と横で画像が非対称となるのを補正した補正画像を示す図である。

図33及び図34はYC422形式のデータにおける色データの横方向の間引きを説明する図であり、図33は輝度データを示す図、図34は色データを示す図である。

- 図35は画像の中心ずれを説明する図である。
- 図36はCCDの画素と撮影画像の関係を示す図である。
- 図37は本発明の第3の実施の形態の画像処理装置における歪補正処理部の詳細な構成を示すブロック図である。
  - 図38は補間回路における補間演算のイメージ図である。
  - 図39は歪補正処理部における内部メモリ部を説明する図である。
- 図40及び図41は、図39の補足説明をする、2ポートSRAMにデータが 書き込まれる様子を説明する図であり、図40は書き込む順番を示す図、図41 は図40に示した書込み順番のデータが16個の2ポートSRAM上のどこに書 き込まれていくかを示す図である。
- 図42は図38の補正座標位置を算出するのに必要なD0を求めるための説明 図である。
  - 図43はエラー処理例を示す図である。
  - 図44は他のエラー処理例を示す図である。
  - 図45は他のエラー処理例を示す図である。
  - 図46は歪補正処理に要するバッファ量について説明する図である。
  - 図47は歪補正処理に要するバッファ量について説明する図である。
- 図48及び図49は歪補正処理に要するバッファ量について説明する図であり、図48はpreULB、postULBの定義を説明する図、図49は歪中

心を跨ぐ時のバッファ開放量を説明する図である。

- 図50はUL処理に伴う開放量の算出方法について説明する図である。
- 図51はUL処理に伴う開放量の算出方法について説明する図である。
- 図52は図51の処理に伴うパイプライン処理の空きについて説明する図である。
  - 図53はUL処理に伴う開放量の算出方法について説明する図である。
- 図54は図53の処理に伴うパイプライン処理の空きについて説明する図である。
  - 図55はUL処理に伴う開放量の算出方法について説明する図である。
  - 図56は格子状の被写体を示す図である。
  - 図57は樽型歪を生じた撮影画像を示す図である。
  - 図58は糸巻き型歪を生じた撮影画像を示す図である。
  - 図59は一般的なデジタルカメラの画像処理手順の概念を示す図である。
- 図60は従来のデジタルカメラの画像処理装置におけるブロック構成を示す図 である。
- 図61は樽型歪を生じた撮影画像を、[式5] によって補正する動作を説明する図である。
- 図62は糸巻き型歪を生じた撮影画像を、[式5]によって補正する動作を説明する図である。

#### 発明を実施するための最良の形態

発明の実施の形態について図面を参照して説明する。

図1は本発明の第1の実施の形態の画像処理装置の全体構成を示すブロック図である。

図1の画像処理装置においては、バス3に接続された各部の制御を行うCPU 4の制御により、CCD1からの撮像信号をプリプロセス回路2で画素欠陥処理、 A/D変換等を行い、得られた画像データを、バス3を介してフレームメモリ5

に一旦記憶する。フレームメモリ5は、SDRAM等で構成され、画像処理前のデータ及び画像処理後のデータを格納するメモリである。次いで、フレームメモリ5から読み出した画像データをバス3を介して、第1データ順序変換部6に入力する。第1データ順序変換部6は、後に図7で説明するように、ブロック単位のデータを記憶可能なメモリを複数、ここでは2つ備えている。第1データ順序変換部6は、フレームメモリ5から行方向にデータを読み出して記憶した後、列方向にデータを順に読み出し、イメージプロセス回路7に出力する。

イメージプロセス回路7は入力したデータに対して所定の画像処理を行って次段の歪補正手段としての歪補正処理部8に転送する。歪補正処理部8は入力したデータに対して歪補正処理を行って次段の第2データ順序変換部9へ転送する。第2データ順序変換部9は、後に図8で説明するように、ブロック単位のデータを記憶可能なメモリを複数、ここでは2つ備えている。第2データ順序変換部9は、 歪補正処理部8から列方向にデータを読み出して記憶した後、行方向にデータを順に読み出し、JPEG処理部10に転送する。そして、JPEG処理部10でJPEG圧縮処理を行い、処理データをフレームメモリ5に一旦記憶し、フレームメモリ5から読み出した処理データをメモリカード等11に記録するようになっている。

歪補正処理部8は、図2に示すように、歪補正後の補正画像の位置(補間位置という、X,Y)とこれに対応した歪補正前の元の画像の位置(X',Y')を生成する補間座標生成部81と、歪補正処理部8の前段ブロックの回路からの画像データの一部を一時的に格納しておくバッファメモリ(以下、単にバッファ)としての内部メモリ部82と、その内部メモリ部82に対する書き込み及び読み出しの制御を行うメモリ制御部83と、変換した歪補正前の画像位置の座標(X',Y')に従って画像処理をしてデータの歪補正をする補間演算部84と、を有して構成されている。

補間座標生成部81は、図2に示すように、補間座標(X,Y)を生成する補間位置生成部811と、生成された補間座標(X,Y)に対して所定の歪補正式[式

1] (後述する)を適用して変換した補正前の座標 (X', Y')を出力する歪補正座標変換部 812 と、補間位置生成部 811 からの補間座標 (X, Y)と歪補正座標変換部 812 からの変換座標 (X', Y')とを選択的に出力可能なセレクタ 813 と、で構成されている。歪補正処理部 8 における補間位置生成部 811, 歪補正座標変換部 812, セレクタ 813, メモリ制御部 8 3 については、制御データを格納した制御レジスタ 8 5 に設定された各ブロックに対する設定値に従って動作する。また、処理結果のステータスなどを CPUから参照することができる。

歪補正処理部8には、図1に示すように、歪補正処理部8が歪補正処理を行う 入力画像範囲を算出する歪補正範囲算出部12が設けられている。歪補正範囲算 出部12は、図11で説明するように、補間座標を生成する座標生成部91と、 生成された補間座標に対して所定の歪補正式を適用して変換した座標を出力する 歪補正座標変換部92と、変換された補正前の座標位置から前記入力画像範囲を 算出する補正範囲検出部93と、を有して構成されている。

以上のように構成された本発明による画像処理装置においては、上記第1データ順序変換部6からJPEG処理部10までは、バス3を介することなく、該バス3とは異なる情報伝達経路でパイプライン処理可能なように接続されていて、画像データを、2次元的な画素配列における所定のプロック単位で転送して処理するようになっている。このようにバス3を介したデータ転送は、フレームメモリ5から第1データ順序変換部6への転送と、JPEG処理部10からフレームメモリ5への転送及びフレームメモリ5からメモリカード11への転送だけとなり、したがってフレームメモリと各イメージプロセス回路との間でデータのやりとりを行っていた従来例(図60)と比べて、バス3によるデータ転送量を大幅に低減させることができ、バス3の負荷を大幅に軽減することが可能となる。また、この図1に示す例においては、画像処理を行うイメージプロセス回路7を1つのみ設けているが、複数あっても構わない。さらに、図では、イメージプロセス回路7の後に歪補正処理部8が設けられているが、逆の構成であっても構わない。

初段のイメージプロセス回路 7 と 2 段目のイメージプロセス回路である歪補正処理部 8 で構成されるイメージプロセス回路部では、各イメージプロセス回路 7 , 8 の前段或いは内部にバイプラインレジスタとして、図示しない小容量のメモリが配置されていて、該小メモリを介して、各イメージプロセス回路 7 , 8 がパイプライン処理動作を行うように構成されている。これらの小容量のメモリは、各イメージプロセス回路 7 , 8 で空間的な画像処理を行う場合、画像処理に必要な周辺データの記憶をするために、また画像データをブロック単位で読み出して配列換えなどを行って処理する必要があるために、設けられている。

図3~5は歪補正処理部8における座標変換の概念図を示している。図3は元データである撮像画像データ、図4は補正画像、図5は図4の補正画像の座標位置(X,Y)に対して図3の元データの座標上に変換された座標位置Pでのデータの座標(X',Y')(この座標Pは元データを実際に構成する複数の画素の位置には必ずしも正確には一致しない座標位置にある)を示している。そのP点での座標位置(X',Y')はそのP点の周辺の画素16点の座標を使って算出されると共にP点での画像データはその周囲の前記16点の画素データを用いて補間演算される。補間演算部84にて点Pの位置のデータをその周囲の16点の画素値(輝度データ)から補間演算するべく処理が行われる。図2の補間位置生成部811で補間座標を生成するというのは、図4の補正画像側でどこの画素位置(X,Y)を指し示すか、ということである。

[式1]では、歪補正後の画素位置(X, Y)に対する歪補正前の画素位置(X', Y')を算出することができる。但し、歪補正前の画素位置(X', Y')は元画像データ上の画素位置に対応した整数値になるとは限らないことは前述した通りである。

[式 1]に従うと、図 4 の座標(X, Y)が図 3 のように座標(X, Y) に変換される。これにより、元データの中のどこの座標位置のデータを作成すれば、よいかを知ることができ、その位置(X, Y) のデータを 1 6 点補間処理を行う補間式を用いて周囲 1 6 点の既知の画素値(図 5 の黒丸印の入力画像データ)

PCT/JP2004/011010

から算出して得ることができる。

## [式1]

$$\begin{cases} \dot{X} = M \cdot (X - X_d) + (X_d + X_{oli}) \\ \dot{Y} = M \cdot (Y - Y_d) + (Y_d + Y_{oli}) \end{cases} \cdot \cdot \cdot (1)$$

$$z^{2} = [S_{x} \cdot (\dot{X} - X_{d})]^{2} + [S_{y} \cdot (\dot{Y} - Y_{d})]^{2} \cdot \cdot \cdot (2)$$

$$\begin{cases} X' = (\dot{X} - X_d) \cdot [1 + A \cdot Z^2 + B \cdot Z^4 + C \cdot Z^6 + \cdots] + X_d \\ Y' = (\dot{Y} - Y_d) \cdot [1 + A \cdot Z^2 + B \cdot Z^4 + C \cdot Z^6 + \cdots] + Y_d \end{cases} \cdots (3)$$

(X, Y)(X', Y') :補正画像内での座標

:撮影画像内での座標

 $(X_d, Y_d)$ (X o11. Y o11)

: 中心ずれ補正

:歪中心位置

М

:範囲補正倍率

 $(S_1, S_1)$ 

: サンプリング比

A. B. C. . . .

-: 歪補正係数

[式 1]におけるZは、歪中心(X d, Yd)から今注目している点(X, Y)ま での距離である。[式 1]によって、補正画像の点(X, Y)に対して歪んでいる 元画像の方の座標 (X', Y') が算出される。[式 1]について補足説明すると、 Mは光学系のデータを用いて理論的に補正した際、補正後に画像がはみ出したり、 不足したりする現象を補正するための補正倍率である。Sx,Syは間引き取込 みなど、縦横で空間的なサンプリング間隔が異なる現象の補正をするためのサン プリング比である。 X off, Y off は歪補正処理によって、歪補正処理後に、被 写体位置が撮影時の位置とはずれてしまう現象の補正をする中心ずれの値である。 る。

本発明に係る[式 1]では、高次項 (具体的には 2'、 2°、 …) を考慮するこ とで、より複雑な陣笠型の歪 (図22参照) にも対応できるようにしている。ま

図61の樽型歪では歪補正するためにM<1として少し縮むようにしておかなければならない。図62の糸巻き型歪の場合は逆に引き伸ばさなければならないので、M>1に設定する。

従来例で述べた [式5] では、樽型歪・糸巻き型歪を補正することを考慮して 記述されている。

次に、図6~図8を参照して画像データの書き込み及び読み出しの処理及び順 序について説明する。

図6は、本実施の形態におけるフレームメモリからの画像データの読み出し順序を説明する図である。

画像データは、通常は、ライン方向、つまり行方向にスイープさせて書き込まれていて、読み出し時は行方向に読み出されるようになっており、1ラインの画像データを全て読み出して、次に隣接するラインの画像データを全て読み出すといった動作を繰り返して行うのが普通である。

これに対して、本発明に係る画像処理装置は、行方向にスイープさせて書き込まれた画像データを、列方向にある一定の長さを単位に、行方向の画像データを順番にイメージプロセス部7に入力し、以降、順次隣の列をイメージプロセス部7に入力して、画像の右端まで繰り返し入力するようにしており、こうして得られる小領域(矩形状の画像データ)をブロックライン(BL)と呼ぶ。

こうした画像データの読み出しを可能にするための第1データ順序変換部6

と、第2データ順序変換部9との構成を、図7及び図8を参照して説明する。図7及び図8は、第1,第2データ順序変換部の構成を示すプロック図である。

第1データ順序変換部6は、図7に示すように、プロック単位の画像データを記憶可能なメモリを複数、ここでは2つ備えており、この2つのメモリ6aとメモリ6bが書き込み側、読み出し側の各スイッチにて書き込み、読み出しが交互に切り換えられるようになっている。すなわち、フレームメモリ5は、書き込み側のスイッチにて、これらメモリ6aとメモリ6bとに切換可能に接続されているとともに、イメージプロセス部7も読み出し側のスイッチにてこれらのモリ6aとメモリ6bとに切換可能に接続されていて、フレームメモリ5がメモリ6aとメモリ6bとの他方がイメージプロセス部7に接続されるように切り換えられる。すなわち、メモリ6a、6bは、フレームメモリ5とイメージプロセス部7との両方に同時に接続されることがないようにスイッチングされ、交互に書き込み、読み出しが行われるようになっている。

フレームメモリ5に記憶されているフレーム画像の一部は、ブロック単位でライン方向に読み出され、一方のメモリ、ここでは例えばメモリ6aに記憶される。これと並行して、メモリ6bからは、既にフレームメモリ5から読み出されて記憶されているブロック単位の画像データが、列方向(縦方向)に順に読み出されて、イメージプロセス部7へ出力される。

フレームメモリ5からメモリ6aへの書き込みと、メモリ6bからイメージプロセス部7への読み出しが終了すると、書き込み側のスイッチおよび読み出し側のスイッチが切り換えられて、次に、フレームメモリ5からメモリ6bへ次のブロック単位の画像データの書き込みが開始されるとともに、メモリ6aからイメージプロセス部7へのブロック単位の画像データの読み出しが開始される。

第2データ順序変換部9も、図8に示すように、上記第1データ順序変換部6 とほぼ同様に構成されていて、ほぼ同様に動作するようになっている。

すなわち、第2データ順序変換部9は、メモリ9a,メモリ9bと、書き込み

側スイッチ、読み出し側スイッチとを有して構成されている。

そして、該第2データ順序変換部9の動作時には、歪補正処理部8からの書き込みがメモリ9aとメモリ9bとの一方に対して列方向(縦方向)に行われ、メモリ9aとメモリ9bとの他方からは行方向(横方向)に読み出しが行われて、JPEG処理部10へ出力されるようになっている。

図9はブロックラインと歪補正処理に必要なメモリ容量 (バッファ容量)の関係を示している。点線枠上の歪曲した4本の実線は、歪補正後の出力データでは直線 (縦1ライン)となるべきデータであるが元データでは歪んでいる。4本の直線のうち、画像中心から離れた左端の直線がもっとも歪曲している。黒丸印は歪補正後の出力データの画素位置に対応する歪補正前の位置を示している。前述の内部メモリ部82では、撮像後の歪んだ入力データがブロックライン内で最大の歪量となる横方向の幅に16点補間を考慮して左右に余裕分をとった範囲を、歪補正処理に必要なバッファ量として確保するようにする。すなわち、これだけのバッファ容量があれば、歪補正可能であるバッファ量、換言すれば歪補正したときに正しい直線形状を作成することが可能なバッファ量を示している。

図10は、ブロックライン幅の設定方法を示すものである。ブロックライン幅を歪補正処理の対象位置に応じて可変設定する例を示している。湾曲した点線は入力側の歪んだデータを示しており、画像中心より離れるほど、すなわち外側にいくほど歪み度合いが大きくなっている。従って、フレームメモリ上の入力データに対してブロックライン幅を設定する際には、その幅は画像中心から離れるほど大きく、中心に近いほど幅を狭くするように設定する。これにより、フレームメモリ5からバス3を介してイメージプロセス回路にデータ転送する際に、データ幅が狭くてよければそのときのバスの専有時間を減らすことができる。

一般的に、画像中心では歪による変形量が小さい。歪補正の処理対象の位置によって、ブロックライン幅(図示の縦方向にスイープする幅)の設定値を変更する。式1には高次項が含まれるため、ブロックライン分の処理に必要な入力範囲を解析的に求めることができない。ブロックライン幅の設定は、歪補正範囲算出

部12の処理結果に基づき、また、CPUで該結果に所定の演算を施すことにより設定する。

図11は、歪補正範囲算出部12の構成を示している。歪補正範囲算出部12は、補間座標(X,Y)を生成する座標生成部91と、生成された補間座標(X,Y)に対して所定の歪補正式(例えば[式1])を適用して変換した座標(X',Y')を出力する歪補正座標変換部92と、変換された補正前の座標位置(X',Y')から歪補正処理に必要な入力画像範囲を算出する補正範囲検出部93と、を有して構成されている。このように歪補正範囲算出部12は、座標生成部91、歪補正座標変換部92、補正範囲検出部93からなり、CPU4からは制御レジスタ94を通じて動作を制御し、範囲算出結果はレジスタ95を通して取得する。歪補正範囲算出部12は、歪補正処理機能に対して付加したもので、歪の変形を考慮して画像データの入力範囲を算出可能とするサポート機能として働く。

次に図12及び図13を参照して、歪補正範囲算出部12における、歪補正処理に必要な入力画像範囲を算出する動作を説明する。

補正画像内で範囲を指定し、入力画像上に座標変換する方法で行う。まず、図 1 2 に示すように補正画像上の所定範囲(例えば 5 行分)の画素位置(格子点位置)を決め、[式 1]にて図 1 3 に示すように出力側の元データ上に座標変換することで、出力側データでの 5 行分のデータの範囲が分かる。処理の設定は、ハードウェアのレジスタ設定で行う。図 1 2 の補正画像上で、例えばスタートは、点(X st, Y st)から間隔 Δ W, Δ H という順番で格子点を生成していき、縦に何点、横に何点かとり、縦に H out 画素、横に Wout 画素となるように設定する。そして、元データ上の位置に変換した結果、補正画像の格子点に対応した交点座標が歪曲した線上に形成されるが、そのブロックラインに対応した歪曲した範囲すなわち外接する図示の太い点線が入力画像範囲として分かればよい。実際には、図 1 2 及び図 1 3 で黒丸印にしてあるような矩形状の周囲 4 辺上の黒丸位置の座標だけ追っていけば、その位置範囲を規定する 4 辺について最大値と最小値から入力画像範囲が分かる。例えば、上の辺は Y Tmax, Y Tmin という間に、下の

辺はY Bmax, Y Bmin という間に収まり、左の辺はX Lmax, X Lmin という間に、右の辺はX Rmax, X Rmin という間に収まっている、というデータを実際に検出して、結果格納用レジスタ95に格納する。ブロックライン処理には、(X Lmin ~ X Rmax, Y Tmin ~ Y Bmax)に補間に必要な画素を加えた範囲が必要である。なお、図13で、出力側の元データ上で、各頂点の変換後の位置を(X 'TL, Y'TL)、(X 'TR, Y'TR)、(X'BL, Y'BL)、(X'BR, Y'BR)としている。

座標生成部 9 1 は、[式 2]で補正画像に必要な座標位置 (X, Y)を生成し、[式 1]で (X', Y')に変換する。上辺の変形範囲を Y Tmin ~ Y Tmax、下辺の変形範囲を Y Bmin ~ Y Bmax、左辺の変形範囲を X Lmin ~ X Lmax、右辺の変形範囲を X Rmin ~ X Rmax、右辺の変形範囲を X Rmin ~ X Rmax、各頂点の変換後の位置を (X'TL, Y'TL)、(X'TR, Y'TR)、(X'BL, Y'BL)、(X'BR, Y'BR)とし、これらを補正範囲検出部 9 3 で検出し、結果格納用レジスタ 9 5 に格納する。

[式2]

$$\begin{cases} X = X_{ST} + k \cdot \Delta W \\ Y = Y_{ST} + \ell \cdot \Delta H \end{cases}$$

k. Qは整数

図14は、歪補正処理の動作を説明するフローチャートである。まず、ステップS 11で、歪補正[式 1]の補正倍率Mを決定する。補正倍率Mを決定の仕方は図15のフローチャートにて後述する。次に、ステップS 12では、決定した補正倍率Mを使って、図10~図13の説明で述べたようにブロックライン処理に必要な入力範囲を補間に必要な部分も考慮して算出し、ステップS 13でこの算出した入力範囲と、歪補正処理に必要な設定値を設定する。そして、ステップS 14で、ブロックライン毎の歪補正処理と次ブロックラインの入力範囲算出を同時実行する。その後、画像の最下段のブロックラインの歪補正処理が行われるまで、ブロックライン毎の歪補正処理と次ブロックラインの入力範囲算出を実行す

る。ステップS 15 において出力画像全体について歪補正処理が終了したか否かを判定することで、ステップS 14 を繰り返し、画像全体について歪補正処理が終わるまで続行して終了する。

このようにすれば、歪補正実行中に、次に歪補正を行う画像入力範囲を算出するので、1つのブロックラインの歪補正が終わったときには次の歪補正処理を行う画像入力範囲が分かっており、歪補正処理を次のブロックラインに対して遅れなく順次スムーズに行なっていくことが可能である。

上記のステップS 11 で、補正倍率Mを適切に決めてやると、図61及び図62で述べた樽型及び糸巻き型のどの歪み画像を補正処理しても画像の出力範囲にきっちりと入れることが可能である。

図15は図14のステップS 11における補正倍率Mの算出方法を説明するフローチャートを示している。まず、ステップS 21で補正倍率Mの初期値として1.0を設定する。次にそのMと歪補正[式1]を用いて出力画像の例えば4辺を座標変換することで歪補正範囲算出部12にて入力画像範囲を算出し(ステップS 22)、元画像の範囲内か否かを判定する(ステップS 23)。ステップS 23で図61のように出力範囲を越えるようであれば、MをΔMだけ減少させた後(ステップS 24)、ステップS 22に戻り、入力画像範囲を算出し、再びステップS 23の範囲内判定を行う。すなわち、少しずつMの値を変えて、ステップS 23で元画像の範囲内か否かを判定し、元画像の範囲内であれば、ステップS 25へ移行する。ステップS 25では前記の入力画像範囲が元画像の範囲内に収まる最大のMか否かを判断する。元画像の範囲内で最大でないならば、MをΔMだけ増加させた後(ステップS 26)、ステップS 22に戻り、ステップS 23~26を行う。ステップS 25で元画像の範囲内で最大ならば、そのときのMを補正倍率として決定する。このとき、範囲算出に用いられる領域は、補正画像の全体である。

なお、図15のフローは、他の方法でも良い。例えば、補正倍率Mの最大及び 最小 Mmax、Mmin を設定し、順次その範囲を2分割して最適なMを追い込む方 法を用いると、計算量が少なくて済む。

ところで、図14におけるステップS 14 において、歪補正処理部8の補正演算に比べて、歪補正範囲算出部12の範囲算出演算の方が演算量が少ない。そこで、補正演算の乗算器を時系列で使うことで、回路規模の削減が可能となる。

歪補正処理を行う際には、[式 1]を見れば分かるように非常に掛算が多くてハードウェア的には回路規模が非常に大きい計算になっている。一般的に乗算器がハードウェアの回路規模を大きくしているので、出来るだけ乗算器を減らすことが好ましい。乗算器制御部を設けて乗算器制御し、タイミングを取りながら、パイプライン的に処理することで、全体の処理速度を下げずに、回路規模を縮小できる。

図16は、図11の歪補正座標変換部92の部分の具体的な構成を示している。 それ以外の部分は、図11と同様である。歪補正座標変換部92では、[式1] のような乗算の多い計算を行うが、その際の複数の乗算をタイミングを図りなが ら時系列で処理することで、乗算器数を減らすことができるように構成してある。

図17は図16のデータ出力のタイミングチャートを示している。まず、 $Z^2$  算出部 921 は、クロックCLKが'1'のタイミングで補間座標(X, Y)を入力する。次に乗算器制御部 922 は、クロックCLKの'2'のタイミングで  $\alpha$ ,  $\beta$ として $Z^2$ を出力し、乗算器制御部 924 は同じタイミング'2'で $\delta$ として歪補正係数Aを出力する。次のクロックCLKの'3'のタイミングで、乗算器 923 は入力される $\alpha$ ,  $\beta$ に基づいて $\gamma$ として $Z^4$ を出力し、乗算器 925 は入力

される $\alpha$ ,  $\delta$ に基づき同じタイミング '3'で $\epsilon$ としてAZ²を出力する。同様に、続くクロックCLKの '4', '5'のタイミングでは、 $\delta$ ,  $\epsilon$ としてB, B Z 'を得、クロックCLKの '6', '7'のタイミングでは、 $\delta$ ,  $\epsilon$ としてC, CZ 'を得る。その結果として、クロックCLKの '8'のタイミングで、補正 座標算出部 926 から補間座標 (X, Y) に対する元データの座標位置 (X', Y')を出力する。

図16の構成では、乗算器は2つしかないが、乗算器を時系列で使うことで、 実際には6つ分の計算をさせている。結果的に乗算器を1/3に減らすことが可 能となる。さらに高次項を考慮する場合でも、同様の動作をさせればよい。

ところで、図17のタイミングチャートを見ると、歪補正座標変換処理においてクロックごとの各変数の出力データには時間的な隙間(空き)があるのが分かる。そこで、パイプライン処理により各変数の出力データを時間的に空きのないように連続的に出力させることが考えられる。

図18は、図17の動作を改善したものであり、パイプライン処理でのデータ出力のタイミングチャートを示している。図17の動作タイミングでは、補間座標(X, Y)の入力から7クロック経過後に出力として元データの座標位置(X, Y)が得られている、つまり、1つ結果が出るまでに7クロック分の時間を要する。これに対して、図18では、10サイクル目に1サイクル目と同じことが起こるので、9サイクルで3画素処理していることになる。つまり、見かけ上3サイクルで1画素処理していることになる。

これまでは、歪補正範囲算出部では1つのチャンネルについてしか歪補正範囲 算出処理を行わない例について述べてきたが、次に前出の1チャンネル分にかかった時間と同じ時間で、3チャンネル分を1つの歪補正範囲算出部で行う方法について説明する。これには、図19に示すように、図12の補正画像上の範囲設定において、注目領域の4辺における範囲算出用画素を例えば1/3の画素数に間引いて設定し演算処理させることで、1チャンネル分の処理時間とほぼ同じ時間で終わることができる。間引き量はレジスタ設定で行う。図19のように間引

いた座標 (黒丸を付したところ) でしか演算しないため、前田の処理時間と同じ時間で複数のチャンネル分に対応でき、しかも回路規模を増大させることがない。 そうすると、例えばカラー画像を扱う場合に、R,G,Bごとに歪補正範囲算出 部を設けなくとも 3 チャンネル分を 1 つの回路部で動作させれば 1 つの歪補正範囲算出部で済み、回路規模を増大させることなく、同じ時間内で済ませることができる。

図20は、3チャンネルの場合の歪補正処理の動作を説明するフローチャートである。図14に示した歪補正処理を3チャンネル分に適用したものである。

図20におけるステップS 31  $\sim S$  33 及びステップS 35 は、図14のステップS 11  $\sim S$  13 及びステップS 15 と同じである。

ステップS 34 では、3 チャンネルにおけるブロックライン毎の歪補正処理と、1 チャンネル目(例えば、R)に対する次ブロックラインの入力範囲算出 $\rightarrow 2$  チャンネル目(例えば、G)に対する次ブロックラインの入力範囲算出 $\rightarrow 3$  チャンネル目(例えば、B)に対する次ブロックラインの入力範囲算出に対する入力範囲算出とを同時に実行する。

これにより、複数のチャンネルを扱う場合に、複数入力信号に対して同時に歪補正処理を行っている間に、複数入力信号に対してそれぞれ次の処理対象であるブロックラインにつき歪補正範囲算出を順次に繰り返して行うことで、1つの歪補正範囲算出部で複数チャンネル分の範囲算出を行わせることが可能である。また、歪補正実行中に、次に歪補正を行う画像入力範囲を算出するので、1つのブロックラインの歪補正が終わったときには次の歪補正処理を行う画像入力範囲が分かっており、歪補正処理を次のブロックラインに対して遅れなく順次スムーズに行なっていくことが可能である。

以上述べたように本発明の第1の実施の形態によれば、歪補正処理を行う入力 画像範囲を算出する歪補正範囲算出部を設けたので、歪補正によって得られる補 正画像は出力すべき出力範囲に対して過不足なく出力することが可能となる。元 データを有効に活用して歪補正処理を行え、糸巻き型歪、樽型歪、及び陣笠型歪 にも対応できる歪補正処理が可能となる。また、ブロックライン毎の処理に必要な入力範囲を算出することができ、データ転送量を最小限にすることが可能となる。

図21は本発明の第2の実施の形態の画像処理装置の全体構成を示すプロック図である。図21は図1から歪補正範囲算出部12を削除した構成となっている。図21における歪補正処理部の構成は図2と同様である。

歪補正座標変換の [式 1] は、あくまでも全画面の中の画像であって、補正画像についてもその座標変換結果の(X', Y')の画像にしても、全画面中で何処に位置しているかを計算している。

ところが、歪補正処理部8に入力される画像データはブロックライン単位である。歪補正処理部8としては、入力される画像データの空間的な位置関係(2次元空間における位置)を知る必要がある。制御レジスタ85は、歪補正処理部8で処理するブロックラインの位置を指定している。

図23及び図24は、補正前の撮像画像データと補正後の補正画像の関係を示している。図23は撮影画像データ、図24は補正画像を示している。図23及び図24は補正画像(出力側画像)の或るブロックラインBLの或る画素位置Aに注目している場合の概念図である。補正画像(出力画像)内の位置Aの座標(X,Y)は、歪補正座標変換の[式1]を用いて(入力画像)内の位置A'の座標(X',Y')に変換される。

座標位置 (X, Y) 及び (X blst, Y blst)、座標位置 (X', Y') 及び (X' blst, Y' blst) は、全画面の原点からの位置を示している。ここでは、原点は、全画面の左上端部としている。

歪補正プロックへ入力される画像データは、符号BLにて示すプロックライン単位である。そのため、まず補正画像の例えば画素Aを歪座標変換処理するには、最終的な補間処理ができるようにプロックラインBL内での座標系における座標位置(x', y')に変換する必要がある。

まず、図24の補正画像(出力画像)の各画素に対する座標位置(X,Y)は、

下記の[式3]で生成する。

[式3]

X = X blst  $+ m \times \Delta X$ 

Y = Y blst  $+ n \times \Delta Y$ 

 $\Delta X$ ,  $\Delta Y$ は補間ピッチで、1.0以上なら縮小画像が生成され、1.0以下なら拡大画像が生成される。座標位置(X blst, Y blst)は歪補正プロックの出力側プロックラインの左肩の位置、すなわち、プロックラインのスタート位置に相当している。(m,n)=(0,0) のとき、X=X blst, Y=Y blst となるので、[式3]から座標位置(X blst, Y blst)を算出できることになる。m=0, n=0から始めて、m, n を例えば交互に 1 ずつ増やしていけば、ブロックラインB L内の全ての画素の座標位置(X, Y) を生成することができる。

このBLに対し、BL内全ての画像の座標位置を[式1]に従って変換すると、図23の変形したハッチング領域BL"にマッピングされる。図23のBL'は、図24のBLを処理するのに必要な入力データの範囲となる。(X'blst, Y'blst)は、BL'の左上位置であり、補間に必要な画素等を考慮すると、変形したハッチング領域の左上位置とは一致しない。BL'は、図1で説明したサポート機能(歪補正範囲算出部12)を利用して設定する。

[式3]で生成された補正後の出力画像の座標位置(X, Y)を、[式1]で座標変換して図23の補正前の入力画像の座標位置(X, Y)を求める。そして、座標変換された座標位置(X, Y)と、座標位置(X, Y blst, Y blst)との差分をとることにより、ブロックライン(太い点線の矩形)の左肩を原点とする座標位置(X, Y)を求めることができる。

その結果、このブロックライン内での座標位置(x',y')に基づき、ブロックライン単位での補間処理を行えることになる。

図23に示す入力画像側の太い点線で示すブロックラインBL'はレジスタ8 5によって設定するが、その値を生成するためには、歪の変形を考慮して画像データの入力範囲(歪補正範囲)を算出可能とするサポート機能が必要となる。こ

のサポート機能は、歪補正処理部8の歪補正処理機能に付加するなどして設ければよい。

次に、図25を参照して歪補正処理フローを説明する。図25は図23及び図24の歪補正処理のフローチャートである。

まず、図24のハッチングを施したところのブロックライン処理を開始する(ステップS41)。前述の[式3]で、(m,n) = (0,0) とおくことにより (ステップS42)、図24のハッチング領域の左肩、すなわちブロックラインのスタート座標位置 (X blst, Y blst) を求める。そして、[式3]から補正画像の座標位置 (X, Y) を求めることができる。この場合、m,nをそれぞれ1ずつ増やしていけば、図24のハッチングで示すブロックラインBL内の各画素の座標位置 (X, Y) を生成することができる (X, Y) を使成することができる (X, Y) を生成することができる (X, Y) を生成することができる (X, Y) をすることができる (X, Y) を生成することができる (X, Y) をする (X, Y) を (

次に、[式 1] を用いて補正画像における座標系の位置 (X, Y) を、補正前の撮影画像における座標系の位置 (X', Y') に変換する (ステップS 44)。

そして、撮影画像における座標系の位置 (X', Y') を、前述した方法で入力プロックラインBL内の座標系の位置 (x', y') に変換する (ステップS 45)。

次に、このプロックラインB L内での座標位置(x', y')に基づいて補間処理を行い、座標位置(X', Y')における 1 6 点補間などで周辺の複数の画素データから補間データを算出することで、1 画素分の補正画像データが得られる(ステップ S 46)。

そして、以上のステップが、補正画像の座標系のBL内全画素について行われたか否かについて判断し (ステップS 47)、終了していなければ次のm, nを設定して (ステップS 48)、ステップS 43  $\sim$  S 47 を繰り返し行い、ステップS 47 の判定で全画素について処理が終了していれば、ステップS 49 に移行する。

ステップS 49 では、全画面 (フレーム) 内の全てのブロックラインBLについて歪補正処理が終了したか否かを判断しており、終了していなければ次の入力ブロックラインBLを選択し、ステップS 41  $\sim$ ステップS 49 を繰り返し、ステップS 49 の判定で全画面ついて処理が終了していれば、終了する。

図26~図29は、図25の変形例とも言うべきものである。

デジタルズームを行う場合や注目する小領域のみを切り出す場合、撮像データの一部しか使わなくても構わない。選択的にCCDから撮像データの一部を取り込むことでメモリを節約することができる。この場合に歪補正をプロックライン単位で行うためには、取り込まれたデータが、撮像素子上でどこに位置するかの情報 (X'imgst, Y'imgst) が必要である。

図26及び図27は、デジタルズームの場合を示し、撮像した画像データから中央部分のみを取り込むものである。図25の場合と異なる点は、上述したように、全画面の中で何処を取り込むかをプリプロセス回路2で設定している点である。この設定に基づいて必要な部分のみを取り込んでおり、その範囲を図26のE'で示す。

まず、図27で全画面の中のデジタルズームする範囲Eの左肩に当たるスタート位置(X imgst, Y imgst)を設定する。次に、ブロックラインBLを設定するが、ここでは梨地にて示す部分である。このとき、取り込み範囲Eの左肩を原点とする、位置座標(X blst, Y blst)が決定し、[式2]と同様にm, nを変化させることで、ブロックラインBL内における各画素の座標を生成することができる。

この結果、座標位置(X imgst, Y imgst)、(X blst, Y blst)、( $m \times \Delta X$ ,  $n \times \Delta Y$ ) から全画面の座標における位置(X, Y)が決定される。

撮影画像における座標位置 (X', Y') は、上記のように決定された座標位置 (X, Y) から [式 1] を用いて求めることができる。

そして次に、撮影画像データにおけるブロックラインBL'の中での座標位置 (x', y') を求める。

まず、取り込まれた撮像データの撮像面における設定範囲E'から左肩の座標 (X') imgst, Y' imgst) が分かる。取り込み範囲E'の左肩を原点とする座標 で、ブロックラインB L 'の左肩の座標位置 (X') blst, Y' blst) はサポート機能を利用して予め求められており、ブロックラインB L '内での座標における座

標位置 (x', y') が決定される。その結果、ブロックラインごとの補間処理が行われる。

図28及び図29は撮像データから或る領域、例えば画面の端の方を切り出す場合である。これは、監視カメラなどにおいて、撮像データの端部分を取り込むような場合に相当する。図28及び図29の場合も、図26及び図27と同様な符号を付してある。図26及び図27と切り出す位置が異なっているだけで、図26及び図27の場合と同様な動作となる。

なお、通常のデジタルカメラでは、CPUが制御レジスタに切り出す領域を設定するため、切り出し位置が分かっており、上記の変換が可能だが、記録後のデータに歪補正処理を行う場合ではタグ等に切り出し領域の位置とサイズを同時に記録する必要がある。このとき、同時に補正係数も記録しておく。

ところで、撮像素子としてのCCDにはモニターモード(撮像した全画面を読み出さないモード)が用意されることが多い。モニターモードでは、ラインが間引かれることが多く、撮像素子における2次元空間的には同一でも、データ上ではサイズが異なることがある。また、プリプロセスにおいて、横方向の画素も間引かれることがある。また、CCDからの撮像データにローバスフィルタ(LPF)などのフィルタリング処理をかけたり、補間処理をしてフレームメモリに取り込むことがある。この場合、縦横のサンプリング比が整数にならない場合が生じる。さらに、JPEGにおけるYCbCrの記録では、CbやCr成分の横方向は2倍の間隔でサンプリングされることが多く、データとしては横方向が縮んだ形になる。これらは、[式1]では、Sx、Syによって補正する。

図30は、撮像時のデータ取り込みにおいて、実際にCCDから送られてくる データが黒丸印のところしかなく、縦方向に3ライン間引いている状態を示して いる。モニターモードでは、このようにCCDからは間引かれたデータしか出力 されず、これをメモリに取り込むと、図31のように間引きによって上下方向に つぶれた画像データとなる。図32のように、空間的に中心から同じ距離にある データを取り出しても、図31のように縦方向では横方向に対して画像が短く出

力されるという現象が現れる。この結果、[式1] による歪補正では、中心からの距離が遠いほど歪補正の効果が大きくなるようにしてあるので、縦と横で、歪補正の効果が変わってしまう。

このように縦と横で画像が非対称となるのを補正する目的で、補正係数Sx, Syが設けられている。図31の場合には、縦方向に伸ばす必要があるため、Sx=1, Sy=4とする。

このSx, Sy の効果により、縦、横のサンプリング比が異なっても正確な歪補正が可能となる。

また、前述のように、サンプリング比が整数でない場合は、Sx, Syも非整数で設定すればよい。さらに、撮像素子の各画素の間隔が縦横で異なる場合でも可能(例えば長方画素)である。

ところで、通常、JPEGですとYCbCrというデータで記録されるのが一般的であるが、そのときの設定として、図33及び図34に示すような場合が考えられる。例えば、<math>YC422という形式のデータの場合は、輝度データに比べて色データについての解像度は横方向が1/2となっている。この場合は、色データについてはSx=2, Sy=1と設定して、補正処理を行えばよい。

ところで、歪の中心と画像の中心が一致しない場合、補正前に中心にあった被写体が、補正後は中心からずれてしまう。[式 1] では、中心ずれ補正値(X off, Y off)で補正することにより、補正前後で画像の中心に来る被写体が変化しないようにすることが可能である。

図35は、画像の中心ずれを説明する図である。

図35は補正画像を示す。前述の図4では、歪の中心と画像の中心が一致している、すなわち、CCDの中心(画像の中心)がレンズ光軸(歪の中心)に一致している場合であった。

図35は、CCDの中心に対して歪の中心がずれている場合である。図35では、歪中心(Xd, Yd)が画像の中心と異なるので、中心ずれを考慮せずに歪補正を行った場合、出力範囲Hに対する画像の中心PがQ点(大きな黒丸にて示

す)にずれる。ユーザにとっては、実際に撮影した画像と歪補正後に表示される画像の中心がずれると、非常に違和感を感じるものである。そこで、元々歪補正前に出力範囲Hの中心にあったデータを、出力範囲に対して中心の位置にくるようにするために、歪補正された画像データの切り出した方を変える。それを行うためには、画像の中心ずれを(X off, Y off)で定義して、画像データの切り出した方を変えればよい。画像の中心ずれ(X off, Y off)を設定することで出力範囲をHからH に移動させ、元々画像の中心Pにあった被写体を、補正後の出力範囲がH においても中心にくるように補正することができる。

図35の実施例によれば、中央の被写体がずれることによる違和感を無くすことが出来る。

以上述べたように本発明の第2の実施の形態によれば、小領域(例えばブロックライン)の空間的な位置を算出可能とし、小領域単位での歪補正処理を実現することができる。また、間引き取り込みされた画像データに対しても、正確な歪補正を行える一方、デジタルズームなど、任意領域を切り出したデータに対しても正確な歪補正を行うことができる。

本発明の第3の実施の形態の画像処理装置の全体構成は、図21と同様である。 図37は、図2における歪補正処理部8の詳細な構成を示している。

図37の各部と図2の各部との対応関係を説明する。図37における補間位置算出回路22が図2の補間位置生成部811に、セレクタ24が図2のセレクタ813に、歪補正係数算出回路21及び補間位置補正回路23が図2の歪補正座標変換部812に、それぞれ対応している。また、図37における2ボートSRAM26が図2の内部メモリ部(内部バッファ)82に対応し、書込みアドレス生成回路28,バッファ空き容量監視回路29,データ送信可否判定回路30,バッファ開放量算出回路31及び読出しアドレス生成回路25が図2のメモリ制御部83に、補間回路27が図2の補間演算部84に、それぞれ対応している。エラー検出回路32は、図2には図示していないがメモリ制御部83に接続して設けられている。エラー検出回路32は、歪補正処理において歪量が大きくなり後述

するpreULB、postULBの設定値を越える歪が発生したときに、エラー (ERROR) としてCPU4に伝える機能を有するものである。

補間位置算出回路 2 2 は、歪補正処理部 8 の後段回路からのリクエストに応じて後段回路へグラント(リクエスト受付)を返したときにそのグラントをトリガとして、1ユニットライン(以下、1 U L という)分の補間位置(X 1, Y 1)を算出するものである。ここで、1 U L とは、前述したブロックライン処理において、メモリ部への書き込み,読み出しの際に、列方向に一列に並んだ一定数分の画像データを書き込んだり,読み出したりする際の一単位である。つまり、1 U L は、ブロックライン(B L)上の列方向に一列に並んだ一定画素数のデータを指している。

補間位置補正回路 2 3 は、歪補正係数算出回路 2 1 からの歪補正係数 F を補間位置 (X 1, Y 1) に乗算して、歪補正前の元データの座標位置 (X', Y') を計算する。セレクタ 2 4 は、(X 1, Y 1) と (X', Y') を選択するもので、歪補正を行う場合は (X', Y') を選択して出力し、拡大・縮小処理 ( リサイズ) のみを行う場合は (X 1, Y 1) を選択して出力する。

2ポートSRAM26は、歪補正処理部8内におけるデータを格納するバッファである。

読出しアドレス生成回路 2 5 は、補間位置に対応する 2 ポート SRAM 1 6 内のアドレス (ADR) を生成したり、 2 ポート SRAM 2 6 からの出力を整列するための制御信号を出力したり、出力画像データに同期して書き込み制御信号WE\_N を出力したり、図 3 8 及び[式 3]に示す D 0 が 2 ポート SRAM 上のどこの位置かを知らせるデータ列制御信号を出力したりする。

書き込みアドレス生成回路 28 は、書き込み制御信号 WE に合わせて内部メモリである 2 ポート SRAM 26 のアドレス (ADDRESS) を生成したり、 1U L分のデータ入力が完了したら、その内部カウンタ (BLC) をカウントアップする。

データ送信可否判定回路30は、BLC値,本回路の動作状態,次のUL先頭

座標, 歪補正処理部 8 の後段回路からのリクエスト (REQ) 状態とから、後段回路からのREQ信号に対してグラント (GRANT\_N) を送信できる状態にあるかを判定し、グラント送信可能なら  $GRANT_N = 1$  とする機能を有する。

補間回路27は、補間位置に対応する画像データにつき、16点補間を行う。 バッファ開放量算出回路31は、現在処理中のUL先頭座標と、次に処理予定の UL先頭座標の整数部の差をバッファ開放量(図50参照)として算出する。

バッファ空き容量監視回路29は、内部バッファとしての2ポートSRAM26に格納されているデータ(UL)量を保持し、バッファに空きがあれば、歪補正処理部8の前段回路に対してリクエスト(REQ=1)を送信する。

次に、図37の歪補正処理部8の回路動作を説明する。

まず、内部メモリ部 (内部バッファ) である 2 ポート SRAM 2 6 に空きがある場合、バッファ空き容量監視回路 2 9 から前段回路に対してデータ要求としてのリクエスト (REQ) を送信すると、バッファ空き容量監視回路 2 9 は前段回路からリクエスト受付としてのグラント (GRANT) を受信し、この受信と同時に 2 ポート SRAM 2 6 に格納可能な UL数を記憶するカウンタ (回路 2 9 内にある)を1つ減らす。1回のリクエストとグラントで1ULを一動作単位としてデータ転送する。上記カウンタが 0 になったらリクエストを取り下げる。

そして、前段回路から書込みアドレス生成回路28ヘデータが流入し、2ポートSRAM26への書込みが行われる。1UL入力毎に書込みアドレス生成回路18の内部カウンタ(BLC)がアップする。

2ポートSRAM26は、補間回路27にて例えば16点補間を行えるように、図39の如く読出しと書込みが同時に行える2ポートSRAMが4×4の計16個で構成されている。

ここで、図39を用いて、2ポートSRAM26を説明するが、メモリの数や各メモリの大きさは異なっていても構わない。例えば、図39では、ブロックラインの幅(ULの長さ)を96としているが、もっと長くしても短くしても構わない。回路規模と補正性能とのバランスで決めればよい。また、4×4(計16

個)も、4点補間であれば $2 \times 2$  (計4個)で構わない。補間方式 (何点で補間するか)に合わせて決めればよい。

図39は、16個の2ポートSRAMからなるメモリ空間で、横方向は入力されるUL順であるが、縦方向は各2ポートSRAMごとに付したアドレスである。Nを整数とし、処理のある時点での状態を説明する。縦方向に並んだ4つの各2ポートSRAMであるNo.0,4,8,12に格納するデータは、4N,4N+4,4N+8,4N+12番目のULのデータであり、No.1,5,9,13に格納するデータは、4N+1,4N+5,4N+9,4N+13番目のULのデータであり、No.2,6,10,14に格納するデータは、4N+2,4N+6,4N+10,4N+14番目のULのデータであり、No.3,7,11,15に格納するデータは、4N+3,4N+7,4N+11,4N+15番目のULのデータである。

横方向に並んだ4つの各2ポートSRAMであるNo.0, 1, 2, 3及びNo.4, 5, 6, 7及びNo.8, 9, 10, 11及びNo.12, 13, 14, 15の各組についても同様に格納されている。

図40及び図41を使って、各2ポートSRAMにデータが書き込まれる様子を説明する。図40及び図41では、図40に示すように、幅8ライン(画素)のブロックラインを想定しており、データは、UL単位に「1,2,…,i,m」、「5,6,…,j,n」、「9,10,…,k,o」、…という順序で入力される。図41は図40に示した書込み順番のデータが4×4の16個の2ポートSRAM No.0~No.15上のどこに書き込まれていくかを示している。例えば No.0,No.4,No.8,No.12 には、図40の左側縦一列の1UL分の画像データ(順番1~mで示されるデータ)が分散されて格納されていく。なお、図39に示される縦方向の2ポートSRAM No.0,No.4,No.8,No.12 の各縦ラインごとに付された表記0~92,1~93,2~94,3~95は、図40で示される各ユニットライン(1~m…、5~n…、9~o…、・・・)の表記とは異なっている。これは、図40及び図41では、4×4の16個の画像データにつき書き込み順が分

かるように  $1 \sim 16$ ,  $a \sim p$ ,  $A \sim P$ , …と 16 個の塊ごとに符号を付してあるためである。図 39 の場合はその縦方向の 2 ボート S R A M No.0, No.4, No.8, No.12 の各縦ラインごとに付された表記は、縦方向の 1 つのULにおけるデータ順に相当する。2 ボート S R A M No.0 の, No.4, No.8, No.12 のそれでは 1 つのUL画素データ No.0  $\sim 95$  が交互に分散して記載されている。従って、図 39 の縦方向に並んだ 4 つの各縦ラインには 1 つのユニットライン(UL)の画素順( $0 \sim 95$ )の何番目の画素であるかを示す表記が付されている。図 39 の 2 ボート S R A M の No.0 の縦方向には 1 しの 1 の 倍数の画素(1 の、1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1 の 1

再び図39に戻って、1UL分のデータは縦方向に並ぶ4つの2ポートSRA Mに1画素づつ順に格納されている。最初のULデータはNo. 0, 4, 8, 1 2 (図39の4Nのライン) に書き込まれる。次のULデータはNo. 1, 5, 9, 13 (図39の4N+1のライン) に書き込まれる。図39のバッファ形態では、歪補正処理によって補間位置がどのように移動しても、バッファ内の任意の座標周辺16点を1回のアクセスで同時に抽出することができる構成としてある。

データ送信可否判定回路 30 が後段回路からリクエスト(REQ\_N)を受信し、次のULデータが送れる状態にあればリクエスト受付(GRANT\_N)を出力する。このリクエスト受付(GRANT\_N)は自分自身へのトリガとなり、補間位置算出回路 22 が動作を開始し、1 UL分動作したら次のUL先頭座標を算出して終了する。

補間位置算出回路 2 2 が動作開始して補間位置 (X1, Y1)を出力するのと同期するようにデータ送信可否判定回路 3 0 からは歪補正係数算出回路 2 1 へ動作トリガ (trig)を送る。歪補正係数算出回路 2 1 も補間位置算出回路 2 2 と同様、1 UL分動作したら次の UL 先頭座標を算出して終了する。

読み出しアドレス生成回路25は、入力される補間座標から、2ポートSRA M26の16個夫々に読み出しアドレスを発行する。

次に、読み出し及び補間の方法について説明する。

補間方法を図38に示す。図38は補間回路27における補間演算のイメージ図である。補正座標位置Pの座標 (X', Y') は前出の [式1] で既に求めてある。この座標における画素値(輝度データ)を求めるのに、座標P(X', Y') の周辺16点の画素データ $D0\sim D15$ から求める。その内、D0が16個のメモリのどのメモリから来ているかが分かれば、D1,  $D2\cdots$ , D15 はD0 に対する位置関係から分かる。後述するように、D0 は補間位置の座標によって求まる。

図42は16個の2ポートSRAMからなるバッファからの読出し例を示している。今、補間位置 (X', Y') がX'=10..., Y'=50... (…は小数点以下の数字) とすると、X'=10...は  $(4\times0+10)$  以上であるから、横方向には2ポートSRAMの4N+10番目のULより若干右側に補間位置が来る。Y'=50...は  $(4\times12+2)$  以上であり、4N+10番目のULで、50番目の画素が格納されているメモリ (No.10) が図7における画素D5を出力するので、D0を出力するメモリは、その左上にあるNo.5となる。

図  $380D0 \sim D15$  に対応する画素データは図 420O部であるので、それらが出力されるようにアドレスを生成する。

No. 0から出力される画像データがDoには対応しない。図10の例では、No. 5からの出力がDoに対応する。このため、どのメモリからどのデータが出力されているかを識別するため、読出しアドレス生成回路25からデータ列制御信号を出力し、これによって、補間演算を行う補間回路27はDoが2ポート

SRAM26のどこから出ているかを認識して16点補間を行う。

画素データD0~D15が分かれば、[式4]の補間式による補間処理を行うことによって、補正座標位置の画素データをDoutとして求めることができる。
[式4]

```
\begin{array}{c} \text{Dout} = k_{x0} \ (k_{y0} \ D_0 + k_{y1} \ D_4 + k_{y2} \ D_8 + k_{y3} \ D_{12} \ ) \\ + k_{x1} \ (k_{y0} \ D_1 + k_{y1} \ D_5 + k_{y2} \ D_9 + k_{y3} \ D_{13} \ ) \\ + k_{x2} \ (k_{y0} \ D_2 + k_{y1} \ D_6 + k_{y2} \ D_{10} \ + k_{y3} \ D_{14} \ ) \\ + k_{x3} \ (k_{y0} \ D_3 + k_{y1} \ D_7 + k_{y2} \ D_{11} \ + k_{y3} \ D_{15} \ ) \end{array}
```

最後のULデータ出力の後、バッファ開放量算出回路31は今処理し終わったUL先頭座標と次のUL先頭座標との差を計算し(図50参照)、必要なくなったデータの蓄積されているバッファを開放するため、バッファ開放量をバッファ空き容量監視回路29へ出力する。ただし、歪中心を跨ぐ時のバッファ開放量は、図49に示すようにpostULB1,postULB2の値変化も考慮した量を開放することが好ましい。図48に示すpreULB、postULBとは、ULを形成する画素のうち、最初の画素の座標位置に対して、行方向に対して前側及び後側に所定幅の領域を設けたもので、これらをそれぞれpreULB、postULBと定義している。歪中心を跨いだ時はバッファ開放量を通常のUL先頭座標の差ではなく、参照値の変わるpostULB(ULB:Unit Line Bufferの略、ユニットラインバッファ)の変化量を参照してバッファ開放量を調節する(調整量は、postULB1-postULB2で、図49参照)。

(UL先頭座標の差) + (調整量) がマイナスになる場合は、マイナス値を記憶しておく。処理が進んでバッファ開放量がマイナス値を超えるまでバッファの開放を行わない。

前述のバッファ開放量の算出と共に、バッファ開放量算出回路31は次のUL 処理にあとどれだけ前段回路からデータが必要かをデータ送信可否判定回路30 へ送信する。

バッファ空き容量監視回路29は前述のバッファ開放量の算出によってバッフ

アに空きができたら、前述の前段回路へのリクエストを行う。

データ送信可否判定回路30は書込みアドレス生成回路28の内部カウンタ (BLC)とバッファ開放量算出回路31からの人力とpreULB値とに基づいて、次のULデータを送れるかどうかを判断する。データ送信可否判定回路30は、後段回路のリクエストに対してリクエスト受付(GRANT\_N)を返す。

エラー検出回路32は、読出しアドレス生成回路25に入力される座標がブロックライン(BL)の左端(図43参照)や右端を逸脱したり、ブロックライン(BL)の上下端(図44参照)を逸脱したり、歪量がpreULB、postULBの設定値を逸脱(図45参照)した場合にエラーを出力する。これらのエラーの出力は、座標を判別して出力することになる。図43及び図44の場合には、エラーを出力するが、処理は継続する。図45の場合も、エラーを出力するが、処理は継続する。図45のpreULB、postULBの場合については、エラーを出力するだけではなく、逸脱した量を記憶し、レジスタに設定してCPU4がデータとして取得できるようにしておく。

このように、ブロックライン処理で、出力側の画像に対して入力側の画像を補間算出しているときに入力画像の範囲からはみ出すようなときがある。その場合、入力範囲にデータがない部分で補間データを生成することになり、エラー検出回路32から補間ができない旨のエラーを出力することになる。

図46にあるように、歪の中心座標に対して、画像の歪み方は対照的になる。また、歪みは一般的に中心に近いほど小さく、離れるほど大きくなる。そこで、BLの両端にあるULの変形を考慮し、バッファを確保すれば、全てのULにおいて、補間処理でデータが不足することは通常はない。そこで、補間する最初の座標(図ではブロックラインBL内の画像データの一番上の×印にて示す先頭座標)に対して前方(図示右側)に所定の領域preULBを、後方(図示左側)に所定の領域postULBを設ける。

サポート機能は、図1の「歪補正範囲算出部」の部分に該当する。図12において、注目領域がBLとなるが、歪補正の座標変換で図13のように変形される。

このとき、X'TL, Y'TL, X Lmin, X Lmax からpreULB1/post ULB1が決められる(図48参照)。同様に、X'TR, Y'TR, X Rmin, X Rmax からpreULB2/postULB2が決められる。

さらに、UL処理において、歪の中心を通過すると、光学的歪の曲がり方が逆方向となる。すると、図46のように、歪中心の左右ではpreULB、postULBの値が異なる。この値を、左右どちらにも対応できるよう、図47のように右側で最も大きいpostULBを採用し、左側で最も大きいpreULBを採用すると、左側又は右側の一方側の処理のときに必要もないのにもう一方側のデータを大きく(すなわち、バッファを広く)確保しておかなければならず、バッファの無駄である。

そこで、preULBとpostULBで予め同じ大きな値で両方決めておくのではなくて、preULBとpostULBを変数としてそれぞれに値を入れるようにする。歪の中心座標を過ぎたら、これらの値を変えてやって確保量を変えるようにする。すなわち、歪中心前後でpreULB、postULBを変化することにより、内部バッファの使い方に無駄をなくし、小さなバッファで比較的大きな歪補正を行える。

pre, postULBをレジスタ85に設定するが、それらの値を生成するためには、歪の変形を考慮して画像データの入力範囲を算出可能とするサポート機能が必要となる。このサポート機能は、歪補正処理部8の歪補正処理機能に付加するなどして設ければよい。メモリ制御部83は、1UL処理中は他の処理によって前記領域preULB,postULBが上書きされないように制御する。前記領域preULB,postULBの設定は、CPU4からレジスタ85(図2参照)に設定しても構わないし、CPUで自動的に計算をして設定してもよい。

歪補正処理において16点補間すると前に述べたが、図48に示すように、歪補正によって補間位置は1UL処理の間にa(ただし、a>0)だけ動き得る。16点補間する関係上、入力画像範囲としてはpre側,post側とも上記間隔aに、補間に必要な画素分の間隔bL,bR を加えた範囲が必要となる。

歪中心を越えると、pre, postULBの値を変えることで、バッファを必要最小限に絞る。また、前述の「歪補正算出部」で、補間分を考慮して結果を出力させてもよい。

歪補正処理部8の持っている内部メモリ部(内部バッファ)82は、図39の 場合、最大で縦96 画素の横に16ライン(画素)である。これを使って歪補正 していくことになる。ブロックライン処理のデータは少なくとも1ULずつ図示 右方向にスイープしていく。一気に数UL開放されることもあるので、必ずしも 1 U L ずつスイープするわけでない。内部メモリ部82は、はじめは空の状態か らスタートするので、16ライン分入ってきて、歪補正処理を行う。これらのユ ニットラインを処理していくと、左側のラインに不要なデータ (1から数UL分 のデータ)が生じることになる。なお、処理したら必ず不要になる訳ではなく、 拡大率が大きい時は不要になるまで数ULかかることもある。不要なデータ分は バッファを開放(すなわち、上書き許可)していって新しいデータを入れていく ことにする。スイープしていく画像は右側にずれていく。最大16ライン読み込 めるサイズしかないので、要らなくなったデータ領域は開放して新しいデータを 順次上書きしていくようにする。不要となったバッファ領域は全て一気に開放し てしまう。その開放量は1ラインであるかもしれないし、5ラインであるかもし れない。例えば、はじめの3ライン分のデータがバッファに入っていたものを以 降の処理に不要であるので開放してしまって次のデータを受け付けるようにし て、次のデータが上書きされる。

ところで、1UL処理が終わった後に開放できるバッファの量は、次のUL先頭座標が決まらなければ分からない (図50参照)。内部バッファは小さいので、使わなくなったデータが格納されている部分をできるだけ早くに開放する為、次のUL先頭座標を算出して開放量を取得し、バッファを開放することで内部バッファを有効に利用できるようにする。ところが、歪補正に対して後段の回路プロックからリクエストが来てそれに対するグラントを返して1ULのデータを後段へ出力し、また次のリクエストが来てからグラントを返した後、座標を求めてと

いうように動作させると、バッファの開放が遅れ、これに伴って、新しいデータの取り込みも遅れ、結果として、バイプライン動作に長い空きができてしまうことが起こり得る。そこで、図51に示すように先の歪補正処理(図示の座標1~nの処理)を行っている段階で、後段の回路ブロックからリクエストに関係なく、座標nの処理が終わったら次の先頭座標n+1を演算して開放量を求め、バッファを早期に開放してしまう。これにより、前段回路ブロックから新たなデータ入力が比較的早く行なわれ、バイブラインの空きを詰めることができる。しかしながら、図51の場合であると、座標nの処理をした後、画素n+1を座標を計算してから処理を終了するので、図52のようにバッファ内に次のUL処理に必要なデータが揃っているのに、後段からのリクエストが連続するとバイブラインに空きが生じる。依然としてバイブラインの空きは存在するので、リクエストが連続した時は、装置全体の動作速度に悪影響を及ぼす恐れがある。

そこで、図51の改善策として、図53のように、なるべく早くに次の座標が 決まってバッファの開放量を求める方法がある。図51のように一番最後に次の 先頭座標を求めるよりももっと早い段階で次のUL先頭座標を取得しておき、必 要なデータが揃っていると判断されたら、次のUL処理を連続して行うことで処 理の空きを小さくする。すなわち、1UL処理が終了する前にULのデータをレ ジスタ等に保持しておいて、次のULの先頭の座標位置を算出することで、予め 次のUL処理の開放量を求めておく。図53では、先の歪補正処理(図示の座標 1~nの処理)の2画素目に次のULの先頭座標を求めておいてバッファ開放量 を早い段階で取得する。これによって、バッファの開放を早くすることができ、 図54に示すように図52に比べてバイプラインの空きをかなり少なくできる。 しかしながら、回路的に複雑となり、制御も困難となる問題点がある。

そこで、図53をさらに改善したのが、図55である。図55では、現在処理中のULが終わった時に開放する量(開放量1)は前のUL処理中に既に分かっている。座標れを算出した後、2つ先のUL先頭座標を計算し、次のUL処理が終わった時に開放できる量(開放量2)を予め求めておく。このようにすると、

図53の場合のようにUL処理中に例外的な座標生成 (座標2の生成)を行う必要がない。このように、次のULの先頭ではなくて次の次の2つ先のULの先頭座標を求めておけば、図53のような例外的な処理がなくなるので、回路的には簡単になる。

以上述べたように本発明の第3の実施の形態によれば、バスの転送量やメモリの容量を大きく増大させることなく、歪補正を実現することができる。すなわち、小さなバッファ容量で比較的大きな歪補正処理を行うことが可能となる。

## 産業上の利用可能性

デジタルカメラ等の電子的撮像装置に用いられる画像処理装置、画像処理方法 及び歪補正方法に広く利用可能であり、回路規模やデータ転送量を増大させるこ と無く、歪補正機能を実現し、歪補正処理を行う場合に、空間的な位置を算出し、 元データである撮影画像データを有効に活用した歪補正処理を行え、糸巻き型歪, 樽型歪,及び陣笠型歪などの歪曲収差に基づく歪に対しても有効な歪補正処理を 行うことができる。

## 請求の範囲

1. 歪補正手段を有する画像処理装置であって、

該画像処理装置は、さらに、

前記歪補正手段が歪補正処理を行う入力画像範囲を算出する歪補正範囲算出部を有することを特徴とする画像処理装置。

2. 前記歪補正範囲算出部は、

補間座標を生成する座標生成部と、

前記生成された補間座標に対して所定の歪補正式を適用して変換した座標を出 力する歪補正座標変換部と、

前記変換された座標位置から前記入力画像範囲を算出する補正範囲検出部と、 を有することを特徴とする請求項1に記載の画像処理装置。

- 3. 前記座標生成部は、歪補正後の出力画像範囲における辺縁部の各画素に対応 する座標のみを用いて補間座標を生成することを特徴とする請求項2に記載の画 像処理装置。
- 4. 前記出力画像範囲は矩形であって、前記座標生成部は、該出力画像範囲の4 辺の各画素に対応する座標のみを用いて補間座標を生成することを特徴とする請 求項3に記載の画像処理装置。
- 5. 前記歪補正範囲算出部は、座標変換により生成された座標に対し、前記出力画像範囲の4辺の各辺に対応する画素の座標の最大値と最小値および前記出力画像範囲の4項点に対応する座標の少なくともいずれかから前記入力画像範囲を算出することを特徴とする請求項1~4のいずれか1つに記載の画像処理装置。
- 6. 前記歪補正座標変換部は、前記所定の補正式に含まれる演算を時系列に処理 することを特徴とする請求項2に記載の画像処理装置。
- 7. 前記座標生成部は、前記歪補正処理のための補間座標に対して所定の間引きを行って座標を求めることを特徴とする請求項2に記載の画像処理装置。
- 8. 前記歪補正範囲算出部は、歪補正処理を行う複数入力信号に対して順次範囲

算出を繰り返して前記入力画像範囲を算出することを特徴とする請求項1に記載の画像処理装置。

- 9. 前記範囲算出を繰り返し処理で行い、入力画像範囲に対して歪補正後の画像 範囲が所定の範囲になるような補正倍率Mを決定することを特徴とする請求項1 又は8に記載の画像処理装置。
- 10. 前記歪補正範囲算出部は、

前記歪補正処理部が歪補正実行中に、次に歪補正を行う画像入力範囲を算出することを特徴とする請求項1に記載の画像処理装置。

11. 歪補正処理を行う画像処理方法であって、

前記歪補正処理を行うに際して、歪補正処理を行う入力画像範囲を算出することを特徴とする画像処理方法。

12. 画像データに対して歪補正処理を行う歪補正手段を有する画像処理装置において、

前記歪補正手段は、

補正前の画像データ内において、補正画像の各画素が対応する位置を所定の補 正式に従って算出する際、撮像面における空間的な位置を記述可能な座標系にお いて算出することを特徴とする画像処理装置。

13. 前記歪補正手段は、

補正画像に含まれる第1の小領域を単位に処理を行い、

前記第1の小領域の各画素の座標位置を前記補正式に従って変換した小領域を 含む撮像面における第2の小領域について、前記撮像面に対応する座標系での位 置を、前記第2の小領域での座標に変換した後に、

前記補正画像の各画素のデータを生成することを特徴とする請求項1に記載の 画像処理装置。

14. 前記画像データは、

撮像データの一部のみを取り込んだ部分画像データであることを特徴とする請求項12又は13に記載の画像処理装置。

15. 前記部分画像データは、

前記撮像データの一部を切り出したデータであることを特徴とする請求項14記載の画像処理装置。

16. 前記部分画像データは、

前記撮像データの横または縦の少なくとも一方向に間引かれたデータであることを特徴とする請求項14記載の画像処理装置。

17. 前記画像データは、

前記撮像データに対してフィルタリング,空間サンプリングまたは補間処理の 少なくともいずれか1つを行って生成されるデータであることを特徴とする請求 項12記載の画像処理装置。

18. 前記画像データは、

各画素が撮像面で空間的に位置する間隔が縦方向及び横方向で異なることを特徴とする請求項12に記載の画像処理装置。

- 19. 画像データにおける各画素の空間的なサンプリング間隔が縦横で異なる場合、歪補正前の画像内における座標を求める補正式は、縦横でのサンプリング間隔の違いを補正する係数を含むことを特徴とする請求項12~18のいずれか1つに記載の画像処理装置。
- 20. 歪補正前の画像内における座標を求める補正式は、

所定量のオフセット補正が可能であることを特徴とする請求項12~19のいずれか1つに記載の画像処理装置。

21. 前記オフセット補正は、

歪の中心と画像の中心が一致しない場合に行うことを特徴とする請求項20に 記載の画像処理装置。

22. 画像データに対して歪補正処理を行う歪補正手段を有する画像処理装置の 歪補正方法であって、

前記歪補正方法は、

補正画像の各画素に対応する座標系での第1の位置を生成するステップと、

前記第1の位置を、歪補正式に従って歪補正前の画像デ<del>ータ内に</del>おける座標系 での第2の位置に変換するステップと、

前記歪補正前の画像データ内における座標系での第2の位置を、撮像面に対応 する座標系を基準とする設定領域内での座標に変換するステップと、

前記設定領域内での座標に基づいて補間処理を行い、前記補正画像の各画素のデータを生成するステップと、

を有することを特徴とする歪補正方法。

- 23. 前記請求項22記載の歪補正方法においては、前記補正画像に含まれる小 領域を単位に処理を行うことを特徴とする歪補正方法。
- 24. 画像データに対して歪補正処理を行う歪補正手段を有する画像処理装置において、

前記歪補正手段は、

前記画像データの一部を格納するメモリ部と、

前記メモリ部に対するデータの書き込みおよび読み込みを制御するメモリ制御 部と、

を有し、

前記メモリ部から読み出した画像データに対する補間演算を行うことを特徴とする画像処理装置。

25. 前記メモリ制御部は、

前記メモリ部への書き込みの際は、列方向に一列に並んだ一定数分の画素からなる画像データ(ユニットライン: UL)を単位として書き込むように制御し、前記メモリ部からの読み出しの際は、歪補正処理後の画像が前記ULを単位として出力されるように、前記メモリ部に格納された画像データに対して読み出し制御することを特徴とする請求項24に記載の画像処理装置。

26. 前記メモリ制御部は、前記ULの最初に処理される画素の座標位置に対して、行方向に対して前側および後側に所定幅の領域(それぞれpreULB、postULB)を設け、前記ULの処理中は他の処理によって前記領域が上書き

されないよう制御することを特徴とする請求項25に記載の画像<del>処理</del>装置。 27. 前記メモリ制御部は、さらに、

前記ULの処理中に、前記歪補正手段の前段からのデータを入力するために開 放可能なバッファ量を算出するバッファ開放量算出回路と、

前記歪補正手段の後段に対するデータ送信の可否を判定するデータ送信可否判定回路とを有し、

前記バッファ開放量算出回路には、前記ULの処理における最初の画素に対する補間座標を中心として前記postULBが入力され、データ送信可否判定回路には前記preULBが入力され、バッファ開放量算出回路は前記バッファ開放量を前記postULBの値を参照して算出し、データ送信可否判定回路は前記preULBの値を参照してデータ送信可否の判定を行うことを特徴とする請求項25又は26に記載の画像処理装置。

- 28. 前記preULB値、postULB値は、それぞれ歪中心に対して前側と後側とで異なる値を設定可能であることを特徴とする請求項26又は27に記載の画像処理装置。
- 29. 前記画像処理装置は、さらにバッファの空き領域を検出するバッファ空き 容量監視回路を有し、

該バッファ空き容量監視回路によりバッファ内の空き領域が検出されると、該空き領域へのデータの書き込みを可能とすることを特徴とする請求項24~27のいずれか1つに記載の画像処理装置。

30. 前記メモリ部は、データのリード動作とライト動作が同時に可能な複数のメモリからなり、

前記メモリ制御部は、さらに、

前記メモリ部へのデータ書込み制御を行う書込みアドレス生成回路と、

前記メモリ部に格納されている画像データから補間演算に必要なデータを同時 に読み出すためのアドレスを生成する読出しアドレス生成回路と、 を有し、

前記データ書込み制御は、同時に読み出すデータをそれぞれ異なるメモリに書き込むものであることを特徴とする請求項24記載の画像処理装置。

- 31. 前記画像処理装置は、さらに、歪補正処理された座標が前記ULの処理における最初の画像に対する補間座標に対し、列方向に前記preULB、postULBを逸脱する座標が生成された時、若しくは、歪補正された座標が前段から入力されない座標となった時にエラーを検出して出力するエラー検出回路を有することを特徴とする請求項26~28のいずれか1つに記載の画像処理装置。
- 32. 前記エラー出力がなされたときはレジスタを再設定して画像処理を再実行することが可能であることを特徴とする請求項26~28のいずれか1つに記載の画像処理装置。
- 33.1ULの処理終了後、次の1ULまたはさらにその次の1ULの処理を開始する際の最初の補間座標が演算された後に1UL単位の処理を終了することを特徴とする請求項25~29のいずれか1つに記載の画像処理装置。
- 34. 画像データに対して歪補正処理を行う画像処理方法において、

前記歪補正処理を行うに際は、データの書き込みおよび読み込みが制御される メモリ部に、前記画像データの一部を格納し、該メモリ部から読み出した画像デ ータに対して補間演算を行うことを特徴とする画像処理方法。

35. 前記画像処理装置は、さらに、前記歪補正手段が歪補正処理を行う入力画像範囲を算出する歪補正範囲算出部を有すること、

を特徴とする請求項26~28のいずれか1つに記載の画像処理装置。

36. 前記歪補正範囲算出部は、所定の歪補正式を適用して座標変換可能であり、 歪補正後の出力画像範囲において、

周辺4辺の各辺に対応する画素を座標変換して生成した変換座標の最大値と最小値、および4項点に対応する画素を座標変換して生成した変換座標、の少なくともいずれかを算出し、前記preULBおよびpostULBは、前記歪補正範囲算出部の出力結果から算出すること、を特徴とする請求項35記載の画像処理装置。

排 ı ħ = H × 靶 Щ 蚁 G ш ۵. っ タ部 1 载 干赛 坐 12 策順 囲 ω. 正出館部 補 理记 甜 歪 補 算 歪処 앮 **a** ジス イ ロ カ イプ 4 フレー 夕郡 一換 **6** ~ 1下 袠 型-<u>o</u>. 策順 ပ K 4 7 J. \_\_ ۵ د د

図



2/30

WO 2005/010

図 3

図 4



図 5



図 6





図 8



図 9



図 1 0



図 1 1



図 1 2



図 1 3



図 1 4



図 1 5





<u>図</u> 1 図 1 7

| X, Y:      | X | . Y         | <u> </u>       |                 |                |                 |                |                 | X, Y  |                |
|------------|---|-------------|----------------|-----------------|----------------|-----------------|----------------|-----------------|-------|----------------|
| α:         |   |             | Z <sup>2</sup> | $\prod$         | Z <sup>4</sup> |                 | Z <sup>6</sup> | <u> </u>        |       | Z <sup>2</sup> |
| <b>ß</b> : |   | · · · · · · | Z <sup>2</sup> | I               | Z <sup>2</sup> |                 |                |                 |       | Z <sup>2</sup> |
| <b>r</b> : |   | · • • • •   |                | Z 4             | [              | Z 6             |                | .,              |       |                |
| δ:         | [ |             | Α              | <u> </u>        | В              |                 | С              | I               |       | Α              |
| ε:         | [ |             |                | AZ <sup>2</sup> | [              | BZ <sup>4</sup> | <u> </u>       | CZ <sup>6</sup> |       |                |
| X', Y':    |   | · · · · ·   |                |                 | r              |                 |                |                 | X',Y' |                |
| (CLK)      | [ | <br>1       | 2              | 3               | 4              | 5               | 6              | 7               | 8     | 9              |

| ∞ |
|---|
| • |
| X |
|   |

| >  <br>  ×  | 2 2   | 2 2  | 24    | 4  | AZ <sup>2</sup> | , ×      | 12    |
|-------------|-------|------|-------|----|-----------------|----------|-------|
| γ × γ × γ   | Z 2   | 22   |       |    | CZ6             | ×        | 1-    |
| × ×         | ] g Z |      |       |    | 0 Z 0           | λ'<br> × | 10    |
|             | 2 6 7 |      |       | O  | CZ 6            |          | 6     |
|             | 2 6   |      | _ 5 6 |    | 824             |          | 80    |
|             | 2 4   | Z 2  | Z 6 T |    | B Z 4           |          | 7     |
|             | 7 4 7 | 22   | 9 Z   | 8  | BZ4             |          | 9     |
| x, Y   X, Y | 2 4   | 2 2  | Z 4   |    | AZZ             |          | က     |
|             | Z 2   | Z 2  | 24    |    | A 2 2           |          | 4     |
|             | 25    | 22   | 24    | A  | AZ <sup>2</sup> |          | 8     |
|             | 2 2   | 22   |       |    |                 |          | 2     |
| ><br>×      |       |      |       |    |                 |          | 1     |
| ∴<br>×<br>× | i     | : 84 | ····· | ٠١ |                 | ,×       | (CLK) |

<u>国</u>









図 2 2



図 2 3



図 2 4







図 2 7





. 図 2 9



図30



図31



図32



図33



図 3 4



図 3 5



図36





図38

| D 1   | D 2      | 03                                               |                                 |
|-------|----------|--------------------------------------------------|---------------------------------|
| D 5   | D 6      | D.7                                              |                                 |
|       | ○── 補正座標 | 要位置P(X'                                          | , Y')                           |
| D 9   | 010      | D11                                              |                                 |
| •     | •        | •                                                |                                 |
| D 1 3 | D 1 4    | D15                                              |                                 |
|       | D5 • D9  | D5 D6<br>● ● ● ● ● ● ● ● ● ● ● ■ ● ■ ■ ■ ■ ■ ■ ■ | D5 D6 D7 ● 補正座標位置P(X'D9 D10 D11 |

図39

## 入力されるULの順(N:整数)

| 4N+4 4N+12 4N+5 4N+13 4N+6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 4N+14        | 4N+7 4N+                   | 15 |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------|----|--|
| 4N /4N+8 / 4N+1 /4N+9 / 4N+2 /4N+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 10 4N+       | 4N+3 \$4N+11\$             |    |  |
| 7 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0<br>4<br>8  | 0 0 0<br>4 4 4<br>8 8 8    |    |  |
| Z     23     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92     92 <t< td=""><td>92 92</td><td>92 92 92</td><td></td></t<> | 92 92        | 92 92 92                   |    |  |
| No. 0 No. 1 No. 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              | No. 3                      |    |  |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1<br>5<br>9  | 1 1 1<br>5 5 5<br>9 9 9    |    |  |
| 23 93 93 93 93 93 93 93 93 93 93                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 93 93        | 93 93 93                   |    |  |
| No. 4 No. 5 No. 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              | No. 7                      |    |  |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2<br>6<br>10 | 2 2 2<br>6 6 6<br>10 10 10 |    |  |
| 23 94 94 94 94 94 94 94 94 94 94                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 94 94        | 94 94 94                   |    |  |
| No. 8 No. 9 No. 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0            | No. 11                     |    |  |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 3<br>7<br>11 | 3 3 3<br>7 7 7<br>11 11 11 |    |  |
| 23 95 95 95 95 95 95 95 95 95 95 95 95 95                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |              | 95 95 95<br>No. 15         |    |  |

図 4 0



図 4 1



ex. 補間位置= (4N+10+α<sub>0</sub>, 50+α<sub>1</sub>) の場合 (α<sub>4</sub>:少数部)



## 各メモリへの読み出しアドレス

No. 5, 6, 7, 9, 10, 11, 13, 14, 15 : 60 (=24\*2+12)

No. 4, 8, 12 : 84 (=24\*3+12)

No. 1, 2, 3 : 61 (=24 \* 2 + 13)

No. 0 : 85 (=24 + 3 + 13)

図 4 3



図 4 4



図 4 5



図 4 6





図 4 8



図 4 9



図 5 0



図 5 1



図 5 2



図 5 3



図 5 4



図 5 5



図 5 6



図 5 7



図 5 8





တ

വ

**図** 

図 6 1



図 6 2

